
import Vue from 'vue'
//创建store状态管理
import Vuex from 'vuex'
Vue.use(Vuex)

//每当初始化项目的时候，就先从localStorage中取一下数据
let car = window.JSON.parse(localStorage.getItem('cart') || '[]')
const store = new Vuex.Store({
    state: {//data
        //购物车数组
        cart: car,//在cart中，应该把每个商品，存储为一个对象{id,count}
    },
    mutations: {//methods
        addToCar(state, goods) {
            let flag = false
            //将商品添加到购物车 
            // 如果购物车中，之前曾经有这条 商品，则只更新数量即可；如果曾经没有，则直接push
            //    state.cart.push(goods)
            state.cart.some(item => {
                if (item.id == goods.id) {
                    //如果找到了对应的商品，则直接更新数量
                    item.count += goods.count
                    flag = true
                    //终止后续循环
                    return true;
                }
            })
            // 如果没有找到，则直接push到购物车
            if (!flag) {
                state.cart.push(goods)
            }

            //为了持久化存储购物车的数据，可以把购物车的商品，序列化出来，存储到localStorage中
            localStorage.setItem('cart', window.JSON.stringify(state.cart))
        },
        updateGoodsCount(state, goods) {
            //根据传递过来的商品信息，更新购物车中商品的数量
            state.cart.some(item => {
                if (item.id === goods.id) {
                    item.count = goods.count
                    return true
                }
            })
            //为了持久化存储购物车的数据，可以把购物车的商品，序列化出来，存储到localStorage中
            localStorage.setItem('cart', window.JSON.stringify(state.cart))
        },
        delFromCart(state, id) {
            //根据id删除vuex中对应的商品
            state.cart.some((item, i) => {
                if (item.id == id) {
                    state.cart.splice(i, 1)
                    return true
                }
            })
            localStorage.setItem('cart', window.JSON.stringify(state.cart))
        },
        changeSelectState(state, obj) {
            //根据提供的obj对象的id和selected属性，更改购物车中商品的选中状态
            state.cart.some(item => {
                if (item.id == obj.id) {
                    item.selected = obj.selected
                    return true
                }
            })
            localStorage.setItem('cart', window.JSON.stringify(state.cart))
        },

    },
    getters: {//computed
        totalCount(state) {
            // 徽标中商品数量
            let c = 0
            //getters的特性，只要依赖的数据变换了，必然会重新计算这个getters的值
            state.cart.forEach(item =>
                c += item.count
            )
            return c
        },
        idstr(state) {
            //获取购物车中所有的商品的id字符串
            let arr = []
            state.cart.forEach(item => arr.push(item.id))
            return arr.join(',')

        },
        countObj(state) {
            //获取购物车中商品的id和商品数量的键值对对应关系
            let o = {}
            state.cart.forEach(item => o[item.id] = item.count)
            return o
        },
        seletedObj(state) {
            //id对用的商品是否被选中
            let o = {}
            state.cart.forEach(item => o[item.id] = item.selected)
            return o
        },
        selectedcount(state) {
            //勾选商品的数量
            let c = 0
            state.cart.forEach(item => {
                //只有这一项商品被选中了，才把数量添加
                if (item.selected) {
                    c += item.count

                }

            })
            return c
        },
        amount(state) {
            //总价
            let c = 0
            state.cart.forEach(item => {
                //只有这一项商品被选中了，才把数量添加
                if (item.selected) {
                    c += item.count * item.price

                }

            })
            return c
        }
    }
})
export default store